<template>
    <el-dialog :title="title" :visible.sync="visible" width="500px"
    :before-close="handleClose">
        <el-form :rules="rules" ref="formData" :model="formData" label-width="100px" 
            label-position="right" style="width: 400px" status-icon>
            <el-form-item label="用户名：" prop="username">
                <el-input v-model="formData.username" maxlength="30"></el-input>
            </el-form-item>
            <el-form-item label="昵称：" prop="nickName">
                <el-input v-model="formData.nickName" maxlength="50"></el-input>
            </el-form-item>
            <el-form-item label="手机号：" prop="mobile">
                <el-input v-model="formData.mobile" maxlength="11"></el-input>
            </el-form-item>
            <el-form-item label="邮箱：" prop="email">
                <el-input v-model="formData.email" maxlength="30"></el-input>
            </el-form-item>
            <el-form-item label="帐号过期：" prop="isAccountNonExpired">
                <!-- (1 未过期，0已过期) -->
                <el-radio-group v-model="formData.isAccountNonExpired" >
                    <el-radio :label="1" border>未过期</el-radio>
                    <el-radio :label="0" border>已过期</el-radio>
                </el-radio-group>
            </el-form-item>
            <el-form-item label="密码过期：" prop="isCredentialsNonExpired">
                <!-- (1 未过期，0已过期) -->
                <el-radio-group v-model="formData.isCredentialsNonExpired" >
                    <el-radio :label="1" border>未过期</el-radio>
                    <el-radio :label="0" border>已过期</el-radio>
                </el-radio-group>
            </el-form-item>
            <el-form-item label="帐号锁定：" prop="isAccountNonLocked">
                <!-- (1 未锁定，0已锁定) -->
                <el-radio-group v-model="formData.isAccountNonLocked" >
                    <el-radio :label="1" border>未锁定</el-radio>
                    <el-radio :label="0" border>已锁定</el-radio>
                </el-radio-group>
            </el-form-item>
            <el-form-item>
                <el-button type="primary" @click="submitForm('formData')" size="mini">确定</el-button>
                <el-button size="mini" @click="handleClose">取消</el-button>
            </el-form-item>
            </el-form>
    </el-dialog>
</template>

<script>

import * as api from '@/api/user'

export default {
    props: {
        title: { // 弹窗的标题
            type: String,
            default: ''
        },
        visible: { // 弹出窗口，true弹出
            type: Boolean,
            default: false
        },
        formData: { // 提交表单数据
            type: Object, 
            default: {}
        },
        
        remoteClose: Function // 用于关闭窗口
    },

    data() {
        return {
            // 校验表单
            rules: {
                 username: [
                     {required: true, message: '请输入用户名', trigger: 'blur'},
                     {min: 4, max: 30, message: '长度在 4 到 30 个字符', trigger: 'blur'}
                 ],
                 
                 nickName: [
                     {required: true, message: '请输入昵称', trigger: 'blur'}
                 ],

                 mobile: [
                     {required: true, message: '请输入手机号', trigger: 'blur'}
                 ],

                 email: [
                     {required: true, message: '请输入邮箱', trigger: 'blur'}
                 ],

                isAccountNonExpired: [
                    {required: true, message: '请选择', trigger: 'change'}
                ],

                isCredentialsNonExpired: [
                    {required: true, message: '请选择', trigger: 'change'}
                ],

                isAccountNonLocked: [
                    {required: true, message: '请选择', trigger: 'change'}
                ]
            }
        }
    },

    methods: {
        
        // 提交
        submitForm(formName) {
            this.$refs[formName].validate((valid) => {
                if (valid) {
                    // 校验通过，提交表单数据
                    this.submitData()
                } else {
                    // console.log('error submit!!');
                    return false;
                }
            })
        },

        async submitData() {
            let response = null
            if(this.formData.id) {
                // 编辑
                response = await api.update(this.formData)
            }else {
                // 新增
                // 初始密码与用户名一致
                this.formData.password = this.formData.username
                response = await api.add(this.formData)
            }

            if(response.code = 20000) {
                this.$message({message: '保存成功', type: 'success'})
                this.handleClose()
            }else {
                this.$message({message: '保存失败', type: 'error'})
            }
        },

        // 关闭窗口
        handleClose() {
            this.$refs['formData'].resetFields()
            this.remoteClose()
        }

    }
}
</script>